package top.zywork.dao;

import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.Mapper;

import java.math.BigDecimal;
import java.util.List;

/**
 * GoodsCommissionDAO数据访问接口<br/>
 *
 * 创建于2019-07-22<br/>
 *
 * @author http://zywork.top 王振宇
 * @version 1.0
 */
@Mapper
public interface GoodsCommissionDAO extends BaseDAO {

    @Override
    List<Object> listAllByCondition(@Param("query") Object queryObj);

    @Override
    List<Object> listPageByCondition(@Param("query") Object queryObj);

    @Override
    Long countByCondition(@Param("query") Object queryObj);

    /**
     * 根据用户编号，商品编号或商品sku编号，分销等级去获取该用户下的商品的分销比例<br/>
     * 获取逻辑为：如果有配置SKU的分销比例，则拿SKU的分销比例，否则拿商品的分销比例<br/>
     * 如果商品的分销比例没有设置，则应该去使用默认的分销配置中的比例
     * @param userId
     * @param goodsId
     * @param goodsSkuId
     * @param distributionLevel
     * @return
     */
    BigDecimal getCommissionPercent(@Param("userId") Long userId, @Param("goodsId") Long goodsId,
                                    @Param("goodsSkuId") Long goodsSkuId, @Param("distributionLevel") Integer distributionLevel);

    /**
     * 根据商品编号或商品SKU编号删除已经配置的佣金比例
     * @param goodsId
     * @param goodsSkuId
     * @return
     */
    int removeAllByGoods(@Param("goodsId") Long goodsId, @Param("goodsSkuId") Long goodsSkuId);
}
